package postgres

import (
	"context"
	"gorm.io/gorm"
	"manager/errors"
	"manager/model"
	"manager/model/entity"
)

var StoreBindUser = &storeBindUser{}

type storeBindUser struct{}

// Create 创建
func (a *storeBindUser) Create(ctx context.Context, m *entity.StoreBindUser) (int64, error) {
	err := GetDB(ctx).Create(m).Error
	return m.Id, err
}

// Find 查找详情
func (a *storeBindUser) Find(ctx context.Context, in *model.StoreBindUserInfoRequest) (*entity.StoreBindUser, error) {
	e := &entity.StoreBindUser{}

	q := GetDB(ctx).Model(&entity.StoreBindUser{})

	if in.Id > 0 {
		err := q.First(&e, in.Id).Error
		return e, err
	}

	count := 0

	if in.StoreId != nil {

		q = q.Where("store_id = ?", in.StoreId)

		count++
	}

	if in.UserId != nil {

		q = q.Where("user_id = ?", in.UserId)

		count++
	}

	if in.IsLeader != nil {

		q = q.Where("is_leader = ?", in.IsLeader)

		count++
	}

	if in.UpdatedAt != nil {

		q = q.Where("updated_at = ?", in.UpdatedAt)

		count++
	}

	if count == 0 {
		return e, errors.New("condition illegal")
	}

	err := q.First(&e).Error
	return e, err
}

// Update 更新
func (a *storeBindUser) Update(ctx context.Context, id int64, dict map[string]interface{}) error {
	return GetDB(ctx).Model(&entity.StoreBindUser{}).Where("id = ?", id).Updates(dict).Error
}

// Delete 删除
func (a *storeBindUser) Delete(ctx context.Context, id int64) error {
	return GetDB(ctx).Delete(&entity.StoreBindUser{}, id).Error
}

// List 列表查询
func (a *storeBindUser) List(ctx context.Context, in *model.StoreBindUserListRequest) (int, []*entity.StoreBindUser, error) {
	var (
		q              = GetDB(ctx).Model(&entity.StoreBindUser{})
		err            error
		total          int64
		storeBindUsers []*entity.StoreBindUser
	)

	if in.StoreId != nil {

		q = q.Where("store_id = ?", in.StoreId)

	}

	if in.UserId != nil {

		q = q.Where("user_id = ?", in.UserId)

	}

	if in.IsLeader != nil {

		q = q.Where("is_leader = ?", in.IsLeader)

	}

	if in.UpdatedAt != nil {

		q = q.Where("updated_at = ?", in.UpdatedAt)

	}

	if err = q.Count(&total).Error; err != nil {
		return 0, nil, err
	}
	if err = q.Order("created_at desc").Limit(in.Size).Offset((in.Index - 1) * in.Size).Find(&storeBindUsers).Error; err != nil {
		return 0, nil, err
	}
	return int(total), storeBindUsers, nil
}

// ExecTransaction db事务执行
func (a *storeBindUser) ExecTransaction(ctx context.Context, callback func(ctx context.Context) error) error {
	return GetDB(ctx).Transaction(func(tx *gorm.DB) error {
		ctx = context.WithValue(ctx, DBCONTEXTKEY, tx)
		return callback(ctx)
	})
}
